<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title>3.computed实现</title>
    <!-- 引入Vue -->
    <script type="text/javascript" src="../../js/vue.js"></script>
  </head>
  <body>
    <!-- 准备好一个容器-->
    <div id="demo">
      <h1>{{school}}</h1>
      <button @click="a">点我修改学校名</button> <br>
      姓：<input type="text" v-model="firstName"> <br>
      名：<input type="text" v-model="lastName"> <br>
      全名：<span>{{fullName}}</span><br>
      全名：<span>{{fullName}}</span><br>
      全名：<span>{{fullName}}</span><br>
      全名：<span>{{fullName}}</span><br>
      全名：<span>{{fullName}}</span><br>
      全名：<span>{{fullName}}</span><br>
      全名：<span>{{fullName}}</span><br>
      全名：<span>{{fullName}}</span><br>
    </div>

    <script type="text/javascript">
      let vm = new Vue({
        el:'#demo',
        data:{
          firstName:'zhang',
          lastName:'san',
          school:'尚硅谷'
        },
        methods:{
          a(){
            this.school += '~'
          }
        },
        computed:{
          fullName:{
            // getter何时调用？ —— ①当初次读取fullName时、②计算时所依赖的数据发生变化时
            // getter中的this是谁？ —— vm
            get(){
              console.log('getter调用了')
              return this.firstName.slice(0,1).toUpperCase()  + this.firstName.slice(1) + '-' + this.lastName
            },
            set(){}
          }
        }
      })

      console.log(vm)
      
    </script>
  </body>
</html>